<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>登录成功界面</title>
</head>
<body>
用户 :<span th:text="${session.uname}"></span></br>
<hr/>
<div>好友列表<!--用户列表显示区-->
    <ul id="userlist">
       <!-- <li><a onclick='showChat("张三")'>张三</a></li>
        <li><a onclick='showChat("李四")'>李四</a></li>-->
    </ul>
</div>
<hr/>
<div id="chatMes"></div><!--显示正在和谁聊天-->
<input id="text" type="text" />
<button onclick="send()">Send</button>
<button onclick="closeWebSocket()">Close</button>
<div id="message"><!--聊天消息显示区-->
</div>

<script type="text/javascript">
    var websocket = null;

    //判断当前浏览器是否支持WebSocket
    if('WebSocket' in window){
        debugger
        websocket = new WebSocket("ws://localhost:9091/websocket");
    }
    else{
        alert('Not support websocket')
    }
    function setMessageInnerHTML(innerHTML){
        document.getElementById('message').innerHTML += innerHTML + '<br/>';
    }

    //接//websocket的服务器端
    //收到消息的回调方法(接收到服务端推送的消息后触发)
    websocket.onmessage = function(event){
         //setMessageInnerHTML(event.data);
        //获取服务器推送过来的消息
        var dataStr=event.data;
        //将dataStr转换为json对象
        var res=JSON.parse(dataStr);
        //将消息显示在网页上
        //判断是否是系统消息
        if(res.isSystem){
            //系统消息
            var names=res.message;
            //好友列表展示
            var userListStr="";
           // var broadcastListStr="";
            for(var name of names){
                userListStr+="<li><a onclick='showChat(\""+name+"\")'>"+name+"</a></li>";
            }
            //渲染好友列表
            document.getElementById("userlist").innerHTML=userListStr;

        }else{
            //不是系统消息
            //将服务端推送的消息进行展示
            setMessageInnerHTML(res.fromName+":"+res.message);
        }
    }
    //选择好//websocket的服务器端
    //友后触发onclick事件，执行showChat()函数
    var toName;
    function showChat(name){
        toName=name;
        document.getElementById("chatMes").innerHTML="正在和"+name+"聊天";
    }
    //发送消息//websocket的服务器端

    function send(){
        //获取输入内容
        var message = document.getElementById('text').value;
        //清除输入区的内容
        document.getElementById('text').value="";
        //显示发送者的消息
        setMessageInnerHTML(message);
        var json={"toName":toName,"message":message};
        //发送数据给服务器
        websocket.send(JSON.stringify(json));
    }

</script>
</body>
</html>